@@ -17,8 +17,10 @@ urlpatterns = [ |
||
| 17 | 17 |
urlpatterns = [ |
| 18 | 18 |
url(r'^g/create$', group_views.group_create_api, name='group_create_api'), # 群组创建 |
| 19 | 19 |
url(r'^g/detail$', group_views.group_detail_api, name='group_detail_api'), # 群组详情 |
| 20 |
+ url(r'^g/update$', group_views.group_update_api, name='group_update_api'), # 群组更新 |
|
| 20 | 21 |
url(r'^g/join$', group_views.group_join_api, name='group_join_api'), # 申请加群 |
| 21 | 22 |
url(r'^g/lock$', group_views.group_lock_api, name='group_lock_api'), # 群组锁定 |
| 23 |
+ url(r'^g/remove$', group_views.group_remove_api, name='group_remove_api'), # 成员移除 |
|
| 22 | 24 |
url(r'^g/pass$', group_views.group_pass_api, name='group_pass_api'), # 申请通过 |
| 23 | 25 |
url(r'^g/refuse$', group_views.group_refuse_api, name='group_refuse_api'), # 申请拒绝 |
| 24 | 26 |
] |
@@ -17,8 +17,11 @@ |
||
| 17 | 17 |
4020 —— 群组不存在 |
| 18 | 18 |
4021 —— 群组已锁定 |
| 19 | 19 |
4022 —— 非群组管理员 |
| 20 |
- 4023 —— 没有锁定权限 |
|
| 21 |
- 4024 —— 没有通过权限 |
|
| 22 |
- 4025 —— 没有拒绝权限 |
|
| 23 |
- 4026 —— 重复加群申请 |
|
| 24 |
- 4027 —— 加群申请不存在 |
|
| 20 |
+ 40220 —— 没有更新权限 |
|
| 21 |
+ 40221 —— 没有锁定权限 |
|
| 22 |
+ 40222 —— 没有移除权限 |
|
| 23 |
+ 40223 —— 没有通过权限 |
|
| 24 |
+ 40224 —— 没有拒绝权限 |
|
| 25 |
+ 4027 —— 重复加群申请 |
|
| 26 |
+ 4028 —— 加群申请不存在 |
|
| 27 |
+ 4029 —— 该用户不在群组 |
@@ -0,0 +1,23 @@ |
||
| 1 |
+# -*- coding: utf-8 -*- |
|
| 2 |
+from __future__ import unicode_literals |
|
| 3 |
+ |
|
| 4 |
+from django.db import models, migrations |
|
| 5 |
+ |
|
| 6 |
+ |
|
| 7 |
+class Migration(migrations.Migration): |
|
| 8 |
+ |
|
| 9 |
+ dependencies = [ |
|
| 10 |
+ ('group', '0003_groupinfo_admin_id'),
|
|
| 11 |
+ ] |
|
| 12 |
+ |
|
| 13 |
+ operations = [ |
|
| 14 |
+ migrations.AlterModelOptions( |
|
| 15 |
+ name='groupphotoinfo', |
|
| 16 |
+ options={'verbose_name': 'groupphotoinfo', 'verbose_name_plural': 'groupphotoinfo'},
|
|
| 17 |
+ ), |
|
| 18 |
+ migrations.AddField( |
|
| 19 |
+ model_name='groupuserinfo', |
|
| 20 |
+ name='deleted_at', |
|
| 21 |
+ field=models.DateTimeField(help_text='\u5220\u9664\u65f6\u95f4', null=True, verbose_name='deleted_at', blank=True), |
|
| 22 |
+ ), |
|
| 23 |
+ ] |
@@ -31,6 +31,17 @@ class GroupInfo(CreateUpdateMixin): |
||
| 31 | 31 |
def __unicode__(self): |
| 32 | 32 |
return unicode(self.group_id) |
| 33 | 33 |
|
| 34 |
+ @property |
|
| 35 |
+ def data(self): |
|
| 36 |
+ return {
|
|
| 37 |
+ 'group_id': self.group_id, |
|
| 38 |
+ 'group_name': self.group_name, |
|
| 39 |
+ 'group_desc': self.group_desc, |
|
| 40 |
+ 'group_from': self.group_from, |
|
| 41 |
+ 'group_lock': self.group_lock, |
|
| 42 |
+ 'created_at': self.created_at, |
|
| 43 |
+ } |
|
| 44 |
+ |
|
| 34 | 45 |
def users(self, user_id): |
| 35 | 46 |
all_users = GroupUserInfo.objects.filter(group_id=self.group_id) |
| 36 | 47 |
|
@@ -60,6 +71,7 @@ class GroupUserInfo(CreateUpdateMixin): |
||
| 60 | 71 |
APPLYING = 0 |
| 61 | 72 |
PASSED = 1 |
| 62 | 73 |
REFUSED = 2 |
| 74 |
+ DELETED = 3 |
|
| 63 | 75 |
|
| 64 | 76 |
USER_STATUS = ( |
| 65 | 77 |
(APPLYING, u'申请中'), |
@@ -74,6 +86,7 @@ class GroupUserInfo(CreateUpdateMixin): |
||
| 74 | 86 |
user_status = models.IntegerField(_(u'user_status'), choices=USER_STATUS, default=APPLYING) |
| 75 | 87 |
passed_at = models.DateTimeField(_(u'passed_at'), blank=True, null=True, help_text=_(u'通过时间')) |
| 76 | 88 |
refused_at = models.DateTimeField(_(u'refused_at'), blank=True, null=True, help_text=_(u'拒绝时间')) |
| 89 |
+ deleted_at = models.DateTimeField(_(u'deleted_at'), blank=True, null=True, help_text=_(u'删除时间')) |
|
| 77 | 90 |
|
| 78 | 91 |
class Meta: |
| 79 | 92 |
verbose_name = _(u'groupuserinfo') |
@@ -47,6 +47,7 @@ def group_create_api(request): |
||
| 47 | 47 |
'message': u'群组创建成功', |
| 48 | 48 |
'data': {
|
| 49 | 49 |
'group_id': group_id, |
| 50 |
+ 'group': group.data, |
|
| 50 | 51 |
'users': group.users(user_id) |
| 51 | 52 |
}, |
| 52 | 53 |
}) |
@@ -77,11 +78,55 @@ def group_detail_api(request): |
||
| 77 | 78 |
'message': u'获取群组详情成功', |
| 78 | 79 |
'data': {
|
| 79 | 80 |
'group_id': group_id, |
| 81 |
+ 'group': group.data, |
|
| 80 | 82 |
'users': group.users(user_id) |
| 81 | 83 |
}, |
| 82 | 84 |
}) |
| 83 | 85 |
|
| 84 | 86 |
|
| 87 |
+def group_update_api(request): |
|
| 88 |
+ group_id = request.POST.get('group_id', '')
|
|
| 89 |
+ admin_id = request.POST.get('admin_id', '')
|
|
| 90 |
+ group_name = request.POST.get('group_name', '')
|
|
| 91 |
+ group_desc = request.POST.get('group_desc', '')
|
|
| 92 |
+ |
|
| 93 |
+ try: |
|
| 94 |
+ admin = UserInfo.objects.get(user_id=admin_id) |
|
| 95 |
+ except UserInfo.DoesNotExist: |
|
| 96 |
+ return JsonResponse({
|
|
| 97 |
+ 'status': 4011, |
|
| 98 |
+ 'message': u'用户不存在', |
|
| 99 |
+ }) |
|
| 100 |
+ |
|
| 101 |
+ try: |
|
| 102 |
+ group = GroupInfo.objects.get(group_id=group_id) |
|
| 103 |
+ except GroupInfo.DoesNotExist: |
|
| 104 |
+ return JsonResponse({
|
|
| 105 |
+ 'status': 4020, |
|
| 106 |
+ 'message': u'群组不存在', |
|
| 107 |
+ }) |
|
| 108 |
+ if group.admin_id != admin_id: |
|
| 109 |
+ return JsonResponse({
|
|
| 110 |
+ 'status': 40220, |
|
| 111 |
+ 'message': u'没有更新权限', |
|
| 112 |
+ }) |
|
| 113 |
+ if group_name: |
|
| 114 |
+ group.group_name = group_name |
|
| 115 |
+ if group_desc: |
|
| 116 |
+ group.group_desc = group_desc |
|
| 117 |
+ group.save() |
|
| 118 |
+ |
|
| 119 |
+ return JsonResponse({
|
|
| 120 |
+ 'status': 200, |
|
| 121 |
+ 'message': u'用户更新成功', |
|
| 122 |
+ 'data': {
|
|
| 123 |
+ 'group_id': group_id, |
|
| 124 |
+ 'group': group.data, |
|
| 125 |
+ 'users': group.users(admin_id) |
|
| 126 |
+ }, |
|
| 127 |
+ }) |
|
| 128 |
+ |
|
| 129 |
+ |
|
| 85 | 130 |
def group_join_api(request): |
| 86 | 131 |
group_id = request.POST.get('group_id', '')
|
| 87 | 132 |
user_id = request.POST.get('user_id', '')
|
@@ -110,7 +155,7 @@ def group_join_api(request): |
||
| 110 | 155 |
|
| 111 | 156 |
if GroupUserInfo.objects.filter(group_id=group_id, user_id=user_id, user_status__in=[GroupUserInfo.APPLYING, GroupUserInfo.PASSED]).exists(): |
| 112 | 157 |
return JsonResponse({
|
| 113 |
- 'status': 4026, |
|
| 158 |
+ 'status': 4027, |
|
| 114 | 159 |
'message': u'重复加群申请', |
| 115 | 160 |
}) |
| 116 | 161 |
|
@@ -149,7 +194,7 @@ def group_lock_api(request): |
||
| 149 | 194 |
}) |
| 150 | 195 |
if group.admin_id != user_id: |
| 151 | 196 |
return JsonResponse({
|
| 152 |
- 'status': 4023, |
|
| 197 |
+ 'status': 40221, |
|
| 153 | 198 |
'message': u'没有锁定权限', |
| 154 | 199 |
}) |
| 155 | 200 |
|
@@ -162,6 +207,60 @@ def group_lock_api(request): |
||
| 162 | 207 |
}) |
| 163 | 208 |
|
| 164 | 209 |
|
| 210 |
+def group_remove_api(request): |
|
| 211 |
+ group_id = request.POST.get('group_id', '')
|
|
| 212 |
+ admin_id = request.POST.get('admin_id', '')
|
|
| 213 |
+ user_id = request.POST.get('user_id', '')
|
|
| 214 |
+ |
|
| 215 |
+ try: |
|
| 216 |
+ admin = UserInfo.objects.get(user_id=admin_id) |
|
| 217 |
+ except UserInfo.DoesNotExist: |
|
| 218 |
+ return JsonResponse({
|
|
| 219 |
+ 'status': 4011, |
|
| 220 |
+ 'message': u'用户不存在', |
|
| 221 |
+ }) |
|
| 222 |
+ try: |
|
| 223 |
+ user = UserInfo.objects.get(user_id=user_id) |
|
| 224 |
+ except UserInfo.DoesNotExist: |
|
| 225 |
+ return JsonResponse({
|
|
| 226 |
+ 'status': 4011, |
|
| 227 |
+ 'message': u'用户不存在', |
|
| 228 |
+ }) |
|
| 229 |
+ |
|
| 230 |
+ try: |
|
| 231 |
+ group = GroupInfo.objects.get(group_id=group_id) |
|
| 232 |
+ except GroupInfo.DoesNotExist: |
|
| 233 |
+ return JsonResponse({
|
|
| 234 |
+ 'status': 4020, |
|
| 235 |
+ 'message': u'群组不存在', |
|
| 236 |
+ }) |
|
| 237 |
+ if group.admin_id != admin_id: |
|
| 238 |
+ return JsonResponse({
|
|
| 239 |
+ 'status': 40222, |
|
| 240 |
+ 'message': u'没有移除权限', |
|
| 241 |
+ }) |
|
| 242 |
+ |
|
| 243 |
+ try: |
|
| 244 |
+ group_user = GroupUserInfo.objects.get(group_id=group_id, user_id=user_id, user_status=GroupUserInfo.PASSED) |
|
| 245 |
+ except GroupUserInfo.DoesNotExist: |
|
| 246 |
+ return JsonResponse({
|
|
| 247 |
+ 'status': 4029, |
|
| 248 |
+ 'message': u'该用户不在群组', |
|
| 249 |
+ }) |
|
| 250 |
+ group_user.user_status = GroupUserInfo.DELETED |
|
| 251 |
+ group_user.deleted_at = tc.utc_datetime() |
|
| 252 |
+ group_user.save() |
|
| 253 |
+ |
|
| 254 |
+ return JsonResponse({
|
|
| 255 |
+ 'status': 200, |
|
| 256 |
+ 'message': u'用户移除成功', |
|
| 257 |
+ 'data': {
|
|
| 258 |
+ 'group_id': group_id, |
|
| 259 |
+ 'users': group.users(admin_id) |
|
| 260 |
+ }, |
|
| 261 |
+ }) |
|
| 262 |
+ |
|
| 263 |
+ |
|
| 165 | 264 |
def group_pass_api(request): |
| 166 | 265 |
group_id = request.POST.get('group_id', '')
|
| 167 | 266 |
admin_id = request.POST.get('admin_id', '')
|
@@ -191,7 +290,7 @@ def group_pass_api(request): |
||
| 191 | 290 |
}) |
| 192 | 291 |
if group.admin_id != admin_id: |
| 193 | 292 |
return JsonResponse({
|
| 194 |
- 'status': 4024, |
|
| 293 |
+ 'status': 40223, |
|
| 195 | 294 |
'message': u'没有通过权限', |
| 196 | 295 |
}) |
| 197 | 296 |
|
@@ -199,7 +298,7 @@ def group_pass_api(request): |
||
| 199 | 298 |
group_user = GroupUserInfo.objects.get(group_id=group_id, user_id=user_id, user_status=GroupUserInfo.APPLYING) |
| 200 | 299 |
except GroupUserInfo.DoesNotExist: |
| 201 | 300 |
return JsonResponse({
|
| 202 |
- 'status': 4027, |
|
| 301 |
+ 'status': 4028, |
|
| 203 | 302 |
'message': u'加群申请不存在', |
| 204 | 303 |
}) |
| 205 | 304 |
group_user.user_status = GroupUserInfo.PASSED |
@@ -211,7 +310,7 @@ def group_pass_api(request): |
||
| 211 | 310 |
'message': u'申请通过成功', |
| 212 | 311 |
'data': {
|
| 213 | 312 |
'group_id': group_id, |
| 214 |
- 'users': group.users(user_id) |
|
| 313 |
+ 'users': group.users(admin_id) |
|
| 215 | 314 |
}, |
| 216 | 315 |
}) |
| 217 | 316 |
|
@@ -245,7 +344,7 @@ def group_refuse_api(request): |
||
| 245 | 344 |
}) |
| 246 | 345 |
if group.admin_id != admin_id: |
| 247 | 346 |
return JsonResponse({
|
| 248 |
- 'status': 4025, |
|
| 347 |
+ 'status': 40224, |
|
| 249 | 348 |
'message': u'没有拒绝权限', |
| 250 | 349 |
}) |
| 251 | 350 |
|
@@ -253,7 +352,7 @@ def group_refuse_api(request): |
||
| 253 | 352 |
group_user = GroupUserInfo.objects.get(group_id=group_id, user_id=user_id, user_status=GroupUserInfo.APPLYING) |
| 254 | 353 |
except GroupUserInfo.DoesNotExist: |
| 255 | 354 |
return JsonResponse({
|
| 256 |
- 'status': 4027, |
|
| 355 |
+ 'status': 4028, |
|
| 257 | 356 |
'message': u'加群申请不存在', |
| 258 | 357 |
}) |
| 259 | 358 |
group_user.user_status = GroupUserInfo.REFUSED |
@@ -265,7 +364,7 @@ def group_refuse_api(request): |
||
| 265 | 364 |
'message': u'申请拒绝成功', |
| 266 | 365 |
'data': {
|
| 267 | 366 |
'group_id': group_id, |
| 268 |
- 'users': group.users(user_id) |
|
| 367 |
+ 'users': group.users(admin_id) |
|
| 269 | 368 |
}, |
| 270 | 369 |
}) |
| 271 | 370 |
|
@@ -1,7 +1,7 @@ |
||
| 1 | 1 |
CodeConvert==2.0.3 |
| 2 | 2 |
Django==1.8.4 |
| 3 | 3 |
MySQL-python==1.2.5 |
| 4 |
-TimeConvert==1.1.3 |
|
| 4 |
+TimeConvert==1.1.6 |
|
| 5 | 5 |
django-curtail-uuid==1.0.0 |
| 6 | 6 |
django-multidomain==1.1.4 |
| 7 | 7 |
django-shortuuidfield==0.1.3 |